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u Background of Invention 

HI [0001] Creative designers in various fields work with materials from many different 
sources when they develop an advertisement, film, brochure, or other finished 
product. These materials may have been created originally by the creative designer, 
but for a different project, and stored in a media library or archive for later reuse. 
They may have been created by colleagues, and stored in an area that allows different 
individuals to collaborate on materials. Or they may have been created by professional 
artists for licensing or sale. These materials are often called rich media files, or assets. 
Rich media files may include, but are not limited to, video, photography, graphics, 
audio, mixed media files, logos, presentations, and text. These media files can exist 
in the widest possible range of formats. It is a ponderous task to manage such assets. 
Annotation mechanisms for such assets include the system described in U.S. Pat. No. 
5,493,677, assigned to the same assignee as the assignee of the present invention. 
Systems to manage such assets include that described in U.S. Pat. No. 6,01 2,068. 



[0002] 

It would be desirable to have a management system for digital media which 
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streamlines the task of accounting for rights to use such media, including copyright 
rights. Systems relating to rights management include those described in U.S. Pat. 
Nos. 4,337,483, 5,201,047, 5,260,999,5,263,158,5,319,705,5,438,508, 5,629,980, 
5,765,1 52, and 5,553,143. 

[0003] Users in different businesses may use different terminology to refer to the various 
media management functions. For example, some may use the term library, while 
others use archive . Some may use project workspace , while others use share or 
collaboration tool. In many systems, changing terminology requires tedious 
programming effort which risks introducing errors into the software. It would be 
□ desirable to have a management system that conveniently permits non-technical 

users to customize such terminology on a per-system basis. U.S. Pat. No. 5,850,561 
describes a glossary construction tool for creating glossary from text. 

[0004] Different companies using the software according to the invention may have 

different corporate culture, image, and system context within the company. It would 
be desirable to have a management system that conveniently permits non-technical 
users to customize the software on a per-system basis with respect to such corporate 
concerns. 



•j i :• 
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[0005] In a typical asset management system, users browse through media file 

collections and view thumbnail images of files to decide which files they want to work 
with. These thumbnails are browseables, or small representations of the actual 
images, videos, or other media files in the system. A browseable is created by 
optimizing an image or video frame for online browsing, so a browseable has lower 
resolution and smaller dimensions than the original file. It is commonplace, however, 
to find that the resolution and dimensions are not well suited to the company. It 
would be desirable to have a management system that conveniently permits a system 
administrator to customize the software in this respect. 

[0006] Natural language processing (NLP) techniques are well known, including their use 
in information retrieval applications (Strzalkowski, 1993), (Strzalkowski, Perez 
Carballo and Marinescu, 1995), (Evans and Zhai, 1996). Past systems have attempted 
to improve upon vocabulary management techniques, for example as described in U.S. 
Pat. Nos. 5,251,316 and 6,125,236. Past approaches for searching multimedia include 
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U.S. Pat. Nos. 6,243,71 3 and 5,794,249. 

[0007] Clustering is well known, for example in U.S. Pat. No. 5,317,507, 5,758,257, 

5,675,819, 5,778,362, and 5,875,446. See also Buckley, Chris, J. Walz, M. Mitra and C 
Cardie, "Using Clustering and Super Concepts within SMART: TREC 
6 tt (http://trec.nist.gov/pubs/trec6/t6_proceedings.html); Zamir, Oren, O. Etzioni, 
Madani, and Karp, KDD "Fast And Intuitive Clustering Of Web Documents;" and Koller, 
Daphne, and Mehran Sahami, ML "Hierarchically Classifying Documents Using Very 
Few Words." Rankings relating to relevance are discussed in U.S. Pat. No. 5,642,502. 

[0008] The evaluation of information retrieval systems became an essential part of the 

field in the early '90s, and was strongly advanced by the TREC evaluations designed at 
NIST beginning in 1 993. The TREC evaluation contains different tracks, but the tracks 
all share the following common features: 

[0009] • They are designed to provide a comparative evaluation between different 
systems, usually provided by different participants. 

[001 0] • The evaluation is done using strict test conditions that contain a set of queries, a 
collection of documents, and relevance judgements. 

[001 1] • The evaluations use evaluation scores such as precision and recall that 
supposedly predict real users' satisfaction from a system. 

[0012] While these evaluations are indeed helpful in comparing the performance of 

different IR systems, they do not provide constant feedback on the performance of a 
live IR system. The base performance of an IR system could be at first evaluated using 
a standard measurement such as the one above, but as more media files are added to 
a system and users submit queries in an uncontrolled manner, it is hard to predict or 
estimate the performance of the system. In addition, if the system does not fall into 
the initial TREC evaluation tracks, it is necessary to develop an independent test case 
— a very costly task. It is desirable to have a better self-evaluation system for such a 
digital asset manager. 

[0013] Known annotation^related systems are discussed in U.S. Pat. No. 5,600,775, 
6,006,241, and 5,938,724. 
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Summary of Invention 

[0014] The software according to the invention incorporates a glossary management tool 
that makes it easy for each client to customize terminology to the needs of a 
particular business. With this tool, termed a glossary manager, a company can 
customize a number of feature names in the system to provide a more familiar 
context for their users. A system administrator can also customize the manner in 
which "thumbnail" or "preview" images are presented. The system performs clustering 
on search queries, and searches media records multi-modally, using two or more 
approaches such as image searching and text searching. An administrator can tune 
search parameters. Two or more streams of metadata may be aligned and correlated 
with a media file, facilitating later searching. The system evaluates itself. It folds 
popularity information into rankings of search results. 

Brief Description of Drawings 

[001 5] The invention will be described with respect to a drawing in several figures, of 
which: 

[0016] Fig. 1 shows a typical rights management editor interaction; 

[001 7] Fig. 2 shows a typical customization interaction screen; 

[001 8] Fig. 3 shows a screen permitting customers to adjust search parameters; 

[001 9] Fig. 4 shows a sample of a face-matching system according to the invention; and 

[0020] Fig. 5 illustrates a viewer according to the invention with text annotation box. 

Detailed Description 

[0021] The inventive software manages media files, or assets, making it possible to store 
and retrieve them, to collaborate with colleagues to edit and work with them, and to 
deliver them, either for further processing or in finished form for use. 

[0022] workflow of the inventive software is designed to provide flexible choices 

among features that support a creative user who works with rich media files. As soon 
as a user logs on to the software (an optional step), she can immediately see i^any 
system-internal messages are waiting in her system email inbox, either sent from 
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other users collaborating with her on media files, or sent automatically by the 
inventive system to notify her of various occurrences that may pertain to her work, 
such as a project update. The user can read her messages, reply to a message, or 
compose a new message to send to another system user. A composed message may 
consist of text only, or it may have a system-internal file attached. 

[0023] The user may wish to work on a project, such as an advertising campaign. She 
enters the project work area, and creates a new project. This creates a virtual 
workspace in the inventive system that is dedicated to holding media files and all their 
related files, including edited versions, colleague comments, official approvals, and so 

St 

i on. She decides which users will be allowed to share access to the project space. She 

may upload files that she has already created into the project work area. From there, 
I she can send a media file off to a colleague for comments, editing, or approval. 

[0024] If she decides to rework a previously created file for use in the new ad campaign, 
^ she can search for the file in the file storage area of the inventive system: She enters 

I search terms, generally either by typing or by speaking into an input device, and finds 

* an appropriate media file. She then saves the file to her new project. She may decide, 

1 instead, to have the full, high-resolution version of that file sent to her for a different 

project. In the inventive system, delivery options for high-resolution files include on- 
line delivery via ftp, http, or special network; via CD delivery, or even via mail delivery 
of the file in analog format. Ordering and file delivery in the inventive system are 
subject to several conditions, which the software verifies and tracks. These conditions 
include whether the user has the proper rights and permissions, not only to view the 
file but also to use or publish it. If use is subject to a fee, the fee must be paid, 
whether by billing, credit card, or other means. If usage requires personal approval, 
the request is routed to the right person and approval is granted and tracked, all 
within the inventive software system. 

[0025] 

Rights management. If a user determines that she needs to use a rights-restricted 
media file, she must engage in a dialogue with the inventive software about her 
planned use of the file. Companies can customize sets of questions that the software 
presents to users, depending on which file a user wants to order. The user may have 
to answer whether she intends to publish the file, where it will be published, to what 
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size audience, at what location, on what date. The answers determine whether the file 
can be made available, and can also determine the price. For example, if she is 
showing ten seconds of a movie for a one-time training seminar in Canada for an 
audience of fifty people, her cost may be far less than making those same ten seconds 
of movie available on the home page of a major entertainment Web site. And making 
the entire movie available on the Web may perhaps not be permitted at any price. 

[0026] When users order files in the software according to the invention, the rights 
management process controls every aspect of the order. A company may allow its 
employees to use its media files for personal use, marketing use, or in an internal 
I organization project. Or they may allow all three uses in different situations. They can 

I track the user's use of the files, they can designate the licensing type for the files and 

f make sure a rights agreement is included, and they can enforce legal or company 

policy restrictions that may apply. The rights management process helps clients 
establish all of these elements so they can apply them appropriately to their stored 

1 media files. 

=• 

I 

[' [0027] The invention described here makes it easier for individual clients to customize a 
I rights management setup so that the software will make the right pricing and 

availability decisions for each projected use. Central to the system is a question- 
answering paradigm: an administrator or a manager decides what questions should be 
presented to each potential user of a file, and what set of multiple choice answers to 
supply. The software maps the questions and answers to a rights and usage package, 
and, if applicable, each package is assigned pricing. 

[0028] For example, an administrator may determine that a file's availability depends on: 

[0029] • What department is giving the presentation? 

[0030] • Who is the audience? 

[0031] • Will the image be included in any handouts? 

[0032] • Will the image be displayed on an overhead? 

[0033] • When is the presentation date? 
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[0034] • Does the work contain images of any sculpture, painting, drawing, or other art 
object that may be copyrighted? 

[0035] The questions, in turn, are grouped appropriately for a company's particular file 

collections, and are assigned to either groups of files or individual files. Questions and 
their answers may serve as fundamental criteria for whether a file is made available; 
they may serve as modifiers to an available file by raising or lowering pricing 
depending on usage; or they may simply be informational questions that do not play a 
role in decision-making, but allow companies to track file use and user needs. 

[0036] The rights management process . When ordering files, users answer questions 
that ask for information about how they are planning to use the files they order. The 
questions a user answers are the usage questions a company designates for each 
possible use. This set of usage questions is called a rights package. Creating a rights 
package is the first step in the rights management process. 



r| [0037] A rights package, or set of questions, is added to other rights packages, to make 
up a rights package group. This allows a company to make more than one rights 
package available for a group of files. A rights package group is added to a particular 
license type. The license type describes the possible ways a file can legally be used. A 
rights agreement is added to define details clearly about the user's rights. In the final 
step, the rights agreement is associated with a particular license type through a 
control table. The control table also contains pricing and approval information for 
each rights package. 

[0038] The core piece of this process is the creation and grouping of questions that cover 
a company's business and legal interests for their stored media file usage. Part of this 
process is completed with what may be termed a rights package question role editor. 
A typical editor interaction is shown in Fig. 1. 

[0039] Glossary Customization Tool and Usability Customization Tool. The software 
according to the invention incorporates a glossary management tool that makes it 
easy for each client to customize terminology to the needs of a particular business. 
With this tool, termed a glossary manager, a company can customize a number of 
feature names in the system to provide a more familiar context for their users. 
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[0040] The system also includes a usability management tool that customizes the 
software interface "look and feel" to more closely reflect a company's corporate 
culture, image, and to reflect the system context within the company. A part of the 
system termed a usability manager allows a company to change system background 
colors, fonts, and the embedded logo. This tool also makes localization into a 
different language simpler. A typical customization interaction screen is shown in Fig. 
2. 

[0041] User-configurable browseable generation. In a typical asset management system, 
users browse through media file collections and view thumbnail images of files to 
decide which files they want to work with. These thumbnails are browseables, or small 
representations of the actual images, videos, or other media files in the system. A 
browseable is created by optimizing an image or video frame for online browsing, so a 
browseable has lower resolution and smaller dimensions than the original file. The 
browseable (the proxy of the actual media file) is what the user sees in the system 
according to the invention, and browseable size is generally set by a system 
administrator for use throughout the system. Importantly, the system permits 
generating these lower-resolution proxy files in a way that can be configured by the 
customer. 

[0042] Natural language processing techniques. In the system according to the invention, 
the natural language processing component is layered. The system architecture 
supports a conventional search algorithm, which operates as a plug-and-play support 
application. The algorithm is then used in a word expansion process. The word 
expansion is applied to both a user's search query, and to the stored files' captions, 
that is, descriptive metadata identifying individual files. 

[0043] When a user submits a search query, the query undergoes several types of NLP 
processing (detailed below), and the result of each element in the processing adds 
new query components (for example, synonyms) and/qr weights (which emphasize or 
dewords depending on their value to the query). The resulting, or processed, query 
contains expanded terms and weighting information that can be passed to any search 
engine. This makes it possible to use multiagent (or "federated search") applications 
as well. 
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[0044] To expand a user search query, once a user query is received, it is divided into 
individual tokens, which may consist of single words or multiwords. (Multiwords are 
words the search engine recognizes as one unit, instead of as separate words. With 
this feature, when a user searches for sea lions, the system does not bring up lions by 
the ocean.) For this process, a variation of conventional pattern matching is used. If a 
single word is recognized as matching a word that is part of a stored multiword, the 
processor decides whether to treat the single word as part of a multiword, based on 
the contents of the stored pattern and the input pattern. Stored patterns include not 
just literal words, but also syntactic categories (such as adjective or nonsemantic 
categories (such as nationality or government entity), or exact matches. If the input 
matches the stored pattern information, then it is interpreted as a multiword rather 
than as independent words. 

[0045] Processing then determines whether the resulting word is a function word (closed- 
class) or content word (open-class). The processor ignores function words. For . 
content words, the related concepts for each sense of the word are retrieved from the 
semantic net. If the root word is unknown, the word is treated as a keyword, requiring 
an exact match. 

[0046] The system then matches the expanded, weighted search query with stored media 
files in order to return search results to the user. Media files are identified by the 
metadata associated with them, e.g. in a caption. Textfiles can be identified by 
metadata associated with them, and also by their content. When users import media 
files into the system, the software provides a workflow to add captions to each file. 
The files are then uploaded into the database, and the file captions are expanded and 
the information stored for later file searching. 



[0047] 



To expand the file captions, the processor looks up each word in the caption or 
text. Words that may be related in the semantic net are located based on stored links, 
and the looked-up word, along with any related words, are all displayed as the 
"expansion" of that word. The processor determines whether the current word or 
phrase corresponds to a proper name, a location, or something else. If it corresponds 
to a name, a name expansion process is invoked that displays the name and related 
names such as nicknames and other variants, based on a linked name file. If the 
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current word or phrase corresponds to a location, a location expansion process is 
invoked that accesses a gazetteer and displays the location and related locations 
based on linked location information found in the gazetteer and supporting files. If 
the current word or phrase is neither a name nor a location, it is expanded using the 
semantic net links and weights associated with those links. Strongly related concepts 
are given high weights, while more remotely related concepts receive lower weights, 
making them less exact matches. Thus, for a query on car, documents or metadata 
containing car and automobile are listed highest, followed by those with sedan, 
coupe, and convertible, and then by more remotely related concepts such as 
transmission, hood, and trunk. 

[0048] Once the expansion is complete, the expanded word or phrase is stored in an 
index database, where it is available for use in searching as described below. 
Processing then returns to expand the next word or phrase in the text or caption. 

[0049] The system according to the invention handles certain words and phrases 

individually. Multiwords are matched as a whole unit, and names and locations are 
identified and looked up in the separate name and location files. Next, noun phrases 
and other syntactic units are identified. A part-of-speech tagger uses linguistic and 
statistical information to tag the parts of speech for sections of the user query. Only 
words that match by part of speech are considered to match, and if two or more parts 
of speech are possible for a particular word, it is tagged with both. After tagging, 
word affixes (i.e. suffixes) are stripped from query words to obtain a word root, using 
conventional inflectional morphology. If a word in a query is not known, affixes are 
stripped from the word one by one until a known word is found. 

[0050] 

An intermediate query is'then formulated to match against the file index database. 
Texts or captions that match queries are then returned, ranked, and displayed to the 
user, with those that match best being displayed at the top of the list. In an exemplary 
system, the searching is implemented by first building a B-tree of ID lists, one for 
each concept in the text database. The ID lists have an entry for each object whose 
text contains a reference to a given concept. An entry consists of an object ID and a 
weight. The object ID provides a unique identifier and is a positive integer assigned 
when the object is indexed. The weight reflects the relevance of the concept to the 
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object's text, and is also a positive integer. 

[0051] To add an object to an existing index, the object ID and a weight are inserted into 
the ID list of every concept that is in any way relevant to the text. For searching, the ID 
lists of every concept in the query are retrieved and combined as specified by the 
query. Since ID lists contain IDs with weights in sorted order, determining existence 
and relevance of a match is simultaneous and fast, using only a small number of 
processor instructions for each concept-object pair. 

[0052] Search Technologies. The system allows users to search for media files with many 
different types of search queries. For example, users may submit search queries by 
speaking them, typing them, copying them, or drawing them. 

[0053] The process of locating a particular file in a large archive is a special area for 

innovation within the inventive software. Files are characterized in several ways. First, 
they have an identifier, generally similar to a filename, which is unique within the 
system and makes it possible to link up all the objects related to a file. These can 
include the actual high-resolution asset, lower-resolution thumbnails or other proxies 
for browsing, and information about the file, or metadata. Searching can be 
performed on the file identifier, or it can be performed on the metadata. In the case of 
metadata searching, it is desirable to offer search alternatives that go beyond the 

Y * » . ■ 

exact matching process involved in a standard keyword search. 

[0054] Some systems use controlled vocabulary searching as an optimization of keyword 
searching. Keyword searches simply match exactly on any word in the user's search 
query that appears in the search target. (In the system according to the invention, the 
search target is the metadata describing a media file.) The set of potential keywords is 
quite large (as large as the vocabulary of English, or whatever language(s) are being 
used). If there are no limitations on the search vocabulary that can be employed, a 
user can enter a search for puma and fail to find any files captioned as mountain lion 
or cougar, even though they all refer to the same thing. Controlled vocabulary is an 
attempt to address this problem, albeit at considerable cost. In a controlled 
vocabulary retrieval system, cataloguers all agree to use the same terms. In practical 
terms, this implies that, when cataloguing, they must check their controlled 
vocabulary lists and be sure not to deviate. Sometimes tools can be built to aid in this 
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process, depending on the size of the controlled vocabulary. Similarly, tools can also 
be provided to searchers to control their search requests. However, controlled 
vocabulary systems do not scale beyond a few thousand terms, since it is impractical 
to look up every word in English for every search. For broader retrieval systems, for 
faster cataloguing, and for simpler searching, a different approach is superior. 

[0055] In addition to standard keyword and Boolean searching, the system software 
incorporates additional advanced technology for locating stored files. Rather than 
limiting searching to a controlled vocabulary, the system software includes natural 
language search, which allows cataloguers and users to employ any words in English 
(or whatever natural language the retrieval system is using). 

[0056] Natural language search incorporates: 

[0057] • a semantic network of concepts 

[0058] • additional linguistic techniques, including: 

[0059] • phrase matching 

[0060] • derivational morphology, in lieu of stemming 
[0061]' - • part of speech tagging 
[0062] • name recognition 
[0063] • location recognition 

[0064] User-tunable Search Parameters. The system according to the invention provides a 
screen for customers to adjust search parameters, to reflect their company use of 
stored media file collections. This is shown in Fig. 3. While the parameters may 
themselves be well-known in a searching system, what is emphasized here is that the 
user (or, more likely, an administrator) can be granted access to such fundamental 
decisions about search as: 

[0065] (a) how good a match has to be before it is displayed to the user, e.g. 50%, and 

[0066] (b) how "creative" the search should be, i.e. how much should the search terms be 
expanded to include more distant synonyms and related terms. 
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[0067] It should be borne in mind that the system according to the invention can be 
carried out on an internet, meaning an IP-based network, and in particular may be 
carried out on the Internet, meaning the global IP-based network. 

[0068] Multimodal Search. Currently, search methods focus on textual input. The current 
invention incorporates new search techniques, arid combines them in novel ways. 

[0069] Image search is becoming useful in commercial applications. In the system 

according to the invention, user search input is provided in a new way. Users may 
wish to select an existing image as example input, so that a search consists of "Give 
me more images like this." Perhaps even more useful is the ability to select part of an 
image, analogous with "Give me more like this part." In the system according to the 
invention, identifying the part may be done in either of two exemplary ways: 

[0070] 1 . Touch screen: user touches the screen to identify the portion of the image that 
feeds into the search. 

[0071] 2. Markup, using pen or other screen drawing metaphor, including through the 
system media viewer, which is described in more detail below. 

[0072] addition, search modalities can be combined. This novel approach to search is 

particularly applicable to multimedia. Examples of combined, or multimodal, searches, 
include: 

[0073] - voice and text 

[0074] - touch screen and text 

[0075] - drawing and voice 

[0076] - drawing and touch screen 

[0077] and so on. 

[0078] 

Vocabulary Management Ideally, the semantic net of concepts is quite large and 
attempts to incorporate every word or term in English (or other language being used 
for cataloguing and searching). No matter how large the semantic net may be, there 
will be a periodic need to expand or edit it. New words appear in English periodically, 
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and, although many may be slang and therefore not particularly important in a 
business context, some will be real new words and will be important enough to 
include. For example, rollerblading and in-line skating are relatively new terms in 
English, and depicting those actions is useful in advertising. So the terms need to be 
added to the semantic net. Semantic net/vocabulary maintenance is generally a 
manual process, particularly where the user has an existing media library with a 
thesaurus and vocabulary management process. Such maintenance can also be 
performed automatically. 

[0079] To maintain a vocabulary for an information retrieval application that accepts user 
queries in natural language, a user maintaining a semantic net would track search 

% 

% queries in a query log. From the query log, he would determine which words are 

: actually novel and are candidates to be added to the system vocabulary, by expanding 

Si; 

* the query log using morphology, and possibly a spell checker and name identifier. The 

remaining terms that were not matched are the basis of a list for adding terms to the 
f vocabulary. 

I 

. [0080] Tools to manage vocabulary include: 

I 

I [0081] • A morphological analyzer. This tool strips off any endings and morphological 
alterations in a query to find the stem, and checks to see if the stem is in the current 
vocabulary. If the stem is not, the user doing the maintenance might try: 

[0082] • A spell checker. This tool uses the conventional algorithms to see if the 
supposedly new word is actually a misspelling of a known word. If it is not a 
misspelling, the user might try: 

[0083] • A name identifier. This tool checks to see if the supposedly new word is in a 

name configuration, in that it follows a known first name in the query. If it does, it is 
added to a candidate name database. If it is not, it is proposed as a possible new word 
to be added to the system's vocabulary. 

[0084] Searching Audio/Video by Timecode Correlation with Search Criteria. Video and 
audio files can be timecoded, or marked such that the software in which: they run can 
locate a specific frame (for videos) or measure (for audio) at any time. Importantly, the 
system according to the invention permits searching timemedia, including video and 
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audio files, by combining two search elements. The first is a standard search, 
including but not limited to natural language search. The second is a time indicator, 
such as a SMPTE (Society of Motion Picture and Television Engineers) standard 
timecode. Face recognition is an additional technology that can be used in searching. 
Face recognition is a subset of the more general technology of object recognition, and 
indeed techniques described here may extend to additional technologies as well. 

[0085] The current state of the art in face recognition technology makes it possible to 

take a manually created, labeled library of faces, and match faces from a video to that 
library. For example, a user might work with a news video and use a face recognition 
program to label Nelson Mandela in it. The output of the face recognition program 
would be a time-coded segment, with start and stop times, of when Nelson Mandela 
was on camera, with the label "Nelson Mandela" attached to the time codes. While face 
recognition currently does not achieve 100% precision or recall, it can still be useful. 
For example, one known system offers a contract rights management capability for 
films that demands time-coded segments with names attached, and assumes that 
users will create those manually, so that the correct contract restrictions for each film 
segment can be attached to the right time codes. Given a small library of the actors in 
a film, it would be possible to do a fast, automated match-up of time codes and . 
actors, even with imperfect face recognition technology. Selecting the correct actor 
from forty publicity shots would be much simpler than selecting from among 
thousands of faces. 

[0086] Importantly, the system according to the invention carries out the automated 
creation of the face library. Required elements include time-coded metadata (for 
example, the voice recognition transcript of a video), and the ability to find the names 
of people in text. Each time a face and a person's name appear at the same time code, 
that occurrence is a potential new entry for the face library. A user may run the 
facematcher for thousands of hours and sift out the recurring matches as the most 
likely. In this way, a reference library of faces is created, and new material can be 
catalogued automatically. 



[0087] 



The software according to the invention approaches this by using alignment 
techniques to match up two or more streams of metadata. For example, a broadcast 
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news program may contain closed captioning for the hearing-impaired. It may also 
contain a separate description of the news footage, probably created manually by the 
news department. The system according to the invention uses alignment to match the 
description, which is not time-coded, with the closed captioning, which is time- 
coded. This process allows the system to add time codes to the non-time-coded 
stream. The software then uses that new, derived stream (i.e. the description with 
newly added time codes), and searches for proper names within it. At the same time, 
using face recognition algorithms on the video stream, the software finds faces. The 
system tries to match up the faces with the proper names that describe who they are. 

; ^ This matched set provides us with a rough cut of a face (or object) reference library. 

^ This is exemplified in Fig. 4. 

tit 

4 . y [0088] Face recognition can also be employed to manage the library or archive of media 
files. Media libraries are assembled over time, often from disparate sources, and may 
contain multiple copies of a single media file, either with the same metadata or with 
different metadata. Duplicate detection is therefore an important element of library 

«!S and archive management, and face recognition (and, more generally, image 

rit 

■ Uik recognition) can be leveraged to provide that capability. More broadly, for video, 

scene detection technology can assist in the process of identifying duplicates so that 

ill 

they can be purged from the library. 

[0089] Clustering and Other Ways to Determine Stored File Usage . Clustering involves 
combining user search queries in such a way that the searches can be analyzed 
usefully to provide answers to business questions. Clustering has received 
considerable attention in document information retrieval (IR) and more recently, in 
video IR as a means of refining retrieval results based on user preferences or profiles, 
and to characterize the marketplace. The prior art contains many examples of 
clustering applied in information retrieval systems, but they all apply to search results 
returned to users rather than search queries submitted by users. In the system 
according to the invention, we cluster search queries by topic. We then use that 
information to adjust the collections of stored files so that the file collections will 
better meet users' needs. . 

[0090] 

This system characterizes the information needs of groups (and subgroups) of 
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[0100] 



[0101] 



users, with respect to a collection of media files (e.g. images, videos, sound clips, 
text, multimedia objects). Some common groupings include: 

• search queries that brought back no files 

• search queries that brought back no files the user was interested in 

• search queries that lead to expressions of user interest or sales 

This system applies clustering technology to user-submitted search queries, and 
to the files retrieved in search results. It also includes: 

• machine learning as applied to the above. 

• characterizing the information needs over time, by user type, or by other 
factors. 

• methods for reporting file collection needs to interested parties (for example, 
media suppliers). The system informs a supplier that pictures of earthquakes are 
selling briskly, or that users keep looking for videos of dance performances but 
cannot find any. 

• methods for adjusting file collections based on the results of the clustering 
analysis, above. 

• novel clustering techniques. These include using a semantic expansion (such as 
the WordNet hierarchical thesaurus) and phrase identification (such as noun phrase, 
and name and location identification) as the basis for the clustering. 

Before user queries can be analyzed, they must be expanded to a "common 
denominator". To expand the user search queries, we use natural language 
techniques. Specifically, we treat each query as if it were metadata within our system, 
as described in the NLP section, above. Each query is expanded through the 
application of a semantic net, so that it contains synonyms and related terms. This 
expansion provides a set of features to which we can apply standard clustering 
technology. 

Obtaining valuable information on user preferences for stored files begins with 
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deciding what information a client wants to understand. The data set can be selected 
according to various criteria, including: 

[01 02] • queries from a particular subset of users (e.g. registered users, users by 
industry, new users) 

[01 03] • queries that lead to success (sale or other indication) 

[01 04] • queries that lead to failure 

[01 05] A first step is to select the data set on which clustering is to be performed. In an 
information retrieval (IR) context, clustering can be performed on queries or on assets 
to be retrieved (documents, images, video, audio, mixed media). A sample query set 
may include short queries, as is standard on Web searches, long queries, as seen in 
TREC (U.S. government-sponsored text retrieval conferences), or as produced by QBE 
(query by example), in which an asset or set of assets are themselves inserted into a 
query. 

[01 06] A second step is to perform analysis on the queries using, for example, linguistic 
methods, such as: 

[0107] • Tokenization: determine word/token boundaries. In English, tokenization mostly 
coincides with spaces between words, with certain complications (Alzheimer's = 1 
token vs. she's = 2 tokens). 

[01 08] • Morphology or stemming: removed tense and plural markers and other affixes 
to find the word root. 

[01 09] • Identify names, locations, noun phrases: using a pattern matcher or other 

methodology, determine words were groupings for special handling. For example, for 
names, match certain kind of variance; for locations, match subset; for noun phrases, 
we to complete and headmatches higher than modifier homematches. 

[01 1 0] A third step is to expand the queries. Ideally, this step includes expansion using a 
thesaurus or semantic net of synonyms, superand other relationships. 

[01 1 1] A fourth step is, for each of the terms in each expanded query, assign a weight 

based on how close that term is to the original query. The exact weighting will vary by 
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application, but the basic understanding is that more closely matching terms are 
weighted close to 100. 

[01 1 2] A fifth step is to create a vector for each expanded query. In order to apply a 
statistical clustering algorithm, we arrange the vectors into a matrix. 

[01 1 3] A sixth step is to apply a statistical clustering algorithm in order to group similar 
queries together. A hierarchical or linear clustering strategy may be used, depending 
on whether the desired clusters are hierarchical or not. Clustering may allow overlap, 
which means that a query may appear in more than one cluster. 

[01 14] A seventh step is to apply the clustering algorithm until the stopping condition is 
met, e.g. the desired number of clusters is obtained, or a combination of cluster 
number and desired distinctiveness of clusters is reached. 

[01 1 5] An eighth step relates to the clusters. Clusters are most useful to a human, 
observer if they bear useful names that reflect the content. Use a semantic net 
hierarchy, combined with term frequency in a reference corpus, to identify the 
lowestterm in the hierarchy that subsumes all the queries. 

[01 1 6] Folding Popularity Into Rankings. Many information retrieval applications currently 
incorporate relevance feedback into their judgements of how to rank search results 
returned to a user. In all cases, however, the past systems utilize explicit user 
feedback, not implicit feedback. That is, they rank files by requiring a user to indicate 
what items he is interested in, once a set of items is returned by a search. Importantly, 
in the system according to the invention, the system discerns implicit popularity 
rankings based on a ranked set of user actions. The system then then uses those 
rankings to resubsequent search results. The user actions from which popularity may 
be determined include, but are not limited to: 

[01 1 7] • whether a file is placed in a projects folder or other work space 

[01 1 8] • whether a file is placed in a shopping cart 

[01 1 9] • whether a file is purchased 

[01 20] 

In addition, implicit popularity rankings may be derived from one user or set of 
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users and applied to a different user or set of users. For example, if User A places a 
media file in a projects folder or shopping cart, the information on her activity can 
also be used to research results for User B, who is in some way similar to user A. In 
another example, if users with ".edu" e-mail addresses buy certain things, it makes 
sense to research results to favor those things, when showing results to other ".edu" 
users. In the system according to the invention, if registered users who work for 
advertising agencies have placed certain items in their shopping carts, other 
advertising agency employees can have their search results re-ranked to favor those 
items. The opposite can be true as well: the same system can be used to disfavor 
certain items because they have been sold too many times to advertising agencies, for 
example. 

[01 21] Retrieval system self-evaluation. The retrieval system according to the invention 
does not answer any of the TREC tracks — a media file is described by a short 
paragraph or by keywords. Even though it is possible to develop a unique test 
collection for purposes of evaluation, it will not necessarily predict the performance of 
new systems, or even for existing ones. 

[01 22] What is now described is a method for ongoing evaluation of IR system 

performance based on search results combined with user feedback. This approach 
enables the system to alert a human system manager about observed degradation in 
the system performance. As the performance evaluation system becomes more 
knowledgeable through methods of machine learning, the system is desirably able to 
change its own parameters in order to improve its performance. 

[01 23] "Performance"as used in this inventive system is a score on a scale of user 
satisfaction with the respect to search results rankings. User satisfaction is 
determined by tracking the user actions together with the system's data. For example, 
for a very good performance, the user would submit a search query and purchase the 
media file that was ranked first. Possible indications of poor performance might 
include a user issuing several consecutive queries, getting thousands of results, and 
terminating the session without further examining any of the media files. 

[01 24] Viewer. The software application according to the invention includes a viewer for 
annotations, or mark-ups, of full motion digital still images, video frames, or other 
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indexed data structures. The viewer, preferably accessible on a personal computer 
with a Web browser, serves as a helper application for the underlying application of 
the system according to the invention. The viewer allows users to view and mark up 
(comment on) media on a separate, see-through lightweight layer. The viewer 
supports annotations that are created and rendered so that they appear overlaid on 
the related media. Position, size, frame number, and other attributes of annotations 
are saved in a separate annotation file, and when played back the annotations appear 
at the saved location and with the saved attributes. Preferably, to the greatest extent 
possible, creating and editing of annotations is be done in WYSIWYG (what you see is 
what you get) fashion. This is illustrated in Fig. 5. 

[0125] The annotations may consist of text, graphics, and digitized : audio, and are stored 
separately from the original file information. An indexing scheme relates individual 
annotations to individual video frames. On full motion video playback, the annotations 
are displayed on the originally annotated frames. One central part of the system ; 
according to the invention is the use of a downloadable, view-only application, which 
enables users who do not have the full power to create annotations nonetheless to be 
able to view annotations created by others. 

[01 26] In an exemplary embodiment, files are stored centrally. Preferably the viewer 
provides security, e.g. SSL, server authentication, and proxy authentication. The 



underlying application according to the invention powers the full lifecycle of digital 
media from content collaboration, deep storage, search and retrieval using a natural 
language search and the ability effectively to move bandwidth-intensive media over 
the Web. The software is preferably Web-based. 



by a Web browser, from a specific link on a Web page that is part of the Web server of 
the system according to the invention. The viewer has the ability to upload annotation 
data back to the Web server. Except for the two actions of launching and uploading, 
the viewer does not require any network connection with the Web server or the Web 
browser. 

The current viewer in the system according to the invention on a PC or Macintosh 
platform allows the user to view and annotate various video, still image, audio, and 



[0127] 



The viewer is a standalone, platform"helper"application that is normally launched 
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text formats, including MPEG, QuickTime, or RealMedia videos, bitmap, jpeg, and tiff 
images, MP3, .wav, .aiff, .au, and .snd audio files, and .pdf document files. The viewer 
currently has nine modes in which it can operate, all of which would be relevant to the 
mobile user. They are: 

[01 29] • annotate a media file 

[01 30] • select a keyframe 

[0131] • select storyboard frames (and optionally a keyframe) 

[01 32] • set the download (cache) directory 

[01 33] • send a message and, optionally, attached files to another user 

[01 34] • download a media file 

[01 35] • upload media files to a project 

[01 36] • upload media files to a public collection 

[0137] • select a playlist 

[01 38] The current (Mac and Windows) viewers can be launched in any of these nine 
modes, generally by receiving an XML annotation file. 

[01 39] Attributes common to all annotation types are: position, size, frame number 
(video only), and page number (multipage document only). All of the graphical 
attributes such as colors and fonts are modifiable using platform-native dialog boxes. 
These attributes can be set for new annotations as well as previously created ones. 

[01 40] For video, each annotation is recorded with the timecode of the specific frame on 
which it was created. When movies with annotations are pUyed back, the viewer stops 
playback at each frame where an annotation exists. The viewer also contains a droplist 
of all annotated frames (by timecode) so that individual annotated frames can be 
viewed quickly. Controls are also provided for stepping by a single frame in either 
direction, as well as a control displaying the timecode of the current frame where the 
viewer is paused. 
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[0141] PDA (or handheld or wearable) version of the viewer builds on the same general 

architecture. The server generates a simple XML annotations file, sends it to the client 
(i.e. the viewer via the Web browser), and handles the returned HTTP messages from 
the viewer. 

[01 42] The following annotation types are desirably supported on a PDA version: 
[tl] 



Annotation types 



Type 


Attributes 


Freehand drawing 
(pen) 


Line width, Color 


Transparent text 


Font name, Font size, Font color 


Sticky note 


Font name, Font size, Font color, Background 
color 


Sound 


Audio data 



[0143] In this way, the system according to the invention supports the full life cycle of 

media; allowing organizations to expedite the process of searching, collaborating. and 
distributing of digital assets, such as imagery, video files, pictures and text 
documents. Users desirably have the freedom to collaborate anywhere at anytime 
using the annotation viewer according to the invention on a PDA. Users are preferably 
able to annotate video and still images with a virtual pen, sticky note, text and even 
voice using a wireless modem. Annotations are preferably capable of being added, 
edited, moved, or deleted. 

[01 44] A PDA-based digital media management solution takes digital delivery and 

collaboration to the next level by eliminating the need of a traditional PC and Ethernet 
connection. In addition, users no longer need to carry laptops to stay up to date on 
work involving video or still images. 

[01 45] Preferably the viewer supports both HTTP authentication and Proxy authentication. 
As an option, the viewer displays a login dialog where the user can enter a user ID and 
password to be used for authentication. Since the viewer is activated and closed 
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frequently, it should not prompt the user to log in each time it connects to the server. 
The viewer instead provides a mechanism for saving the user ID and password on the 
local workstation (in encrypted form) and passing this information to the server 
without any prompting. It is desirable that the viewer support SSL encryption for all of 
its HTTP requests. 
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